.loader-container {
  height: 6px;
  width: 300px;
  position: absolute;
  top: 50%;
  left: 50%;
  margin-top: -3px;
  margin-left: -300px;
  background-color: transparent;
  background-image: -o-linear-gradient(left, #5bd8ff, #ff0000);
  background-image: -webkit-gradient(linear, left top, right top, from(#5bd8ff), to(#ff0000));
  background-image: linear-gradient(left, #5bd8ff, #ff0000);
  -webkit-box-shadow: inset 0 -2px 2px rgba(0, 0, 0, 0.4);
          box-shadow: inset 0 -2px 2px rgba(0, 0, 0, 0.4);
  -webkit-border-radius: 3px 0 0 3px;
          border-radius: 3px 0 0 3px; }

.loader-container:after {
  content: "";
  display: block;
  position: absolute;
  right: 0;
  top: 50%;
  width: 1em;
  height: 1em;
  -webkit-border-radius: 50%;
          border-radius: 50%;
  margin-top: -0.5em;
  margin-right: -1em;
  background-image: -o-linear-gradient(top, #000000, #212121);
  background-image: -webkit-gradient(linear, left top, left bottom, from(#000000), to(#212121));
  background-image: linear-gradient(top, #000000, #212121); }

.loader-container.done:after {
  background: Red; }

.run .runner {
  content: "";
  position: absolute;
  right: 0;
  height: 100%;
  width: 0%;
  background-color: transparent;
  background-image: -o-linear-gradient(top, #000000, #212121);
  background-image: -webkit-gradient(linear, left top, left bottom, from(#000000), to(#212121));
  background-image: linear-gradient(top, #000000, #212121);
  -webkit-animation: loader 5s linear;
          animation: loader 5s linear; }

.meter {
  position: absolute;
  top: 0;
  right: 0;
  font-size: 2em;
  margin-top: .3em;
  color: #ff0000;
  -webkit-animation: meter 5s linear;
          animation: meter 5s linear;
  text-shadow: 0 -1px 0 #333333; }

.meter:after {
  content: "%"; }

@-webkit-keyframes loader {
  0% {
    width: 100%; }
  100% {
    width: 0%; } }

@keyframes loader {
  0% {
    width: 100%; }
  100% {
    width: 0%; } }

@-webkit-keyframes meter {
  0% {
    color: #5bd8ff; }
  100% {
    color: #ff0000; } }

@keyframes meter {
  0% {
    color: #5bd8ff; }
  100% {
    color: #ff0000; } }

/* Decoration */
#progress-box {
  position: absolute;
  right: 20px;
  bottom: 60px;
  z-index: 199999;
  width: 300px; }

@media (max-width: 769px) {
  .loader-container {
    margin-left: -184px; } }
